<!doctype html>
<html lang="en">

<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  
  <meta name="generator" content="Hugo 0.98.0" />

  
  <meta name="description" content="走在通往幸福的路上">
  

  
  <link rel="apple-touch-icon" sizes="180x180" href="https://blog.v5u.win/apple-touch-icon.png">

  
  <link rel="icon" type="image/png" sizes="32x32" href="https://blog.v5u.win/favicon-32x32.png">

  
  <link rel="icon" type="image/png" sizes="16x16" href="https://blog.v5u.win/favicon-16x16.png">

  
  <link rel="manifest" href="https://blog.v5u.win/site.webmanifest">

  
  <link rel="mask-icon" href="https://blog.v5u.win/safari-pinned-tab.svg" color="">

  <meta name="msapplication-TileColor" content="">

  <meta name="theme-color" content="">

  
  <link rel="stylesheet" href="https://blog.v5u.win/css/bootstrap.min.css" />

  
  <title>MySQL8 | 为吾优</title>
  

  <style>
body {
  min-width: 300px;
}

.custom-navbar {
  margin-bottom: 1em;
  height: 60px;
}

.custom-navbar a {
  display: inline-block; 
  padding: 18px 0;
  margin-right: 1em; 
  font-weight: bold; 
}

.custom-navbar a:hover,
.custom-navbar a:focus {
  text-decoration: none; 
}

@media print {
  .custom-navbar {
    display: none;
  }
}

article {
  padding-bottom: 1em;
}

img {
  max-width: 100%;
}


body {
  background-color: #fff;
}



body {
  color: #212529;
}



a {
  color: #007bff;
}



a:hover,
a:focus {
  color: #0056b3;
}



.custom-navbar {
  background-color: #212529;
}



.custom-navbar a {
  color: rgba(255,255,255,.75);
}



.custom-navbar a:hover,
.custom-navbar a:focus {
  color: rgba(255,255,255,1);
}



.container {
  max-width: 800px;
}





</style>
</head>

<body>
  <nav class="custom-navbar">
  <div class="container">
    
    <a href="/">文章</a>
    
    <a href="/tags/">标签</a>
    
    <a href="/about/">关于</a>
    
    <a href="/index.xml">RSS</a>
    
  </div>
</nav>
  
  <div class="container">
    <article>
      <h1>MySQL8</h1>
<p>
  <small class="text-secondary">
  
  
  2019-03-20
  </small>
  

<small><code><a href="https://blog.v5u.win/tags/mysql">mysql</a></code></small>

</p>
<p>mysql5.7 —&gt;mysql8 的升级</p>
<p>MySQL8的加密方式有变化</p>
<p>命令行查看MySQL8 账户的加密方式</p>
<!-- raw HTML omitted -->
<!-- raw HTML omitted -->
<p>在mysql8之前的版本使用的密码加密规则是<code>mysql_native_password</code>，但是在mysql8则是<code>caching_sha2_password</code>。</p>
<p>Navicat不支持 caching_sha2_password 这种加密方式，所以升级后 Navicat 不能连接 MySQL8</p>
<h4 id="navicat-连接-mysql8-的解决方案有三">Navicat 连接 mysql8 的解决方案有三：</h4>
<h5 id="方案一-重新创建一个账号设此账号的加密方式为-mysql_native_password使用这个账号">方案一 重新创建一个账号，设此账号的加密方式为 mysql_native_password，使用这个账号</h5>
<p>create user ‘fanjinlong’@’%’ identified with mysql_native_password by ‘333’;</p>
<p>create user ‘your username’@’%’ identified with caching_sha2_password by ‘your password’;</p>
<p>ps. 此路不通，该账号无法创建 database 和 table</p>
<h5 id="方案二-修改root-的密码加密方式刷新">方案二 修改root 的密码加密方式，刷新</h5>
<p>ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘password’ PASSWORD EXPIRE NEVER; # 更改root 的加密方式</p>
<p>ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘password’;# 重置密码</p>
<p>FLUSH PRIVILEGES; #刷新数据库</p>
<h5 id="方案三-更换mysql8-客户端">方案三 更换MySQL8 客户端</h5>
<p>关于 caching_sha2_password</p>
<p>MySQL提供了两个身份验证插件，可以为用户帐户密码实现SHA-256哈希：</p>
<p>sha256_password：实现基本的SHA-256身份验证。</p>
<p>caching_sha2_password：实现SHA-256身份验证（如sha256_password），但在服务器端使用缓存以获得更好的性能，并具有更广泛的适用性的附加功能。</p>
<blockquote>
<p>在MySQL 8.0中，caching_sha2_password是默认的身份验证插件而不是 mysql_native_password。</p>
</blockquote>
<blockquote>
<p>要使用通过caching_sha2_password插件进行身份验证的帐户连接到服务器，您必须使用安全连接或支持使用RSA密钥对进行密码交换的未加密连接，如本节后面所述。无论哪种方式， caching_sha2_password插件都使用MySQL的加密功能。</p>
</blockquote>

    </article>
  </div>

  
  
  

  
</body>

</html>